查看原文
其他

学习区块链必读:如何10分钟搭建Libra

方圆 高可用架构 2019-11-28

导读:Libra作为Facebook发布的区块链系统,自开源以来受到大家的广泛关注。本文作者先简要介绍了Libra的一些特点和基本使用方法,适合对区块链有兴趣的广大工程师阅读。


Libra发布也有一段时间了,虽然美国国会各种危难,但是Facebook在这段时间里依然对其改进不少,例如Libra发布时使用了move ir,现在已经基本完全增强并公开了move语言。Libra本身的目的在于支付手段,可以非常方便的进行零成本转账。

Libra使用Rust语言开发,个人猜测Libra开发团队使用Rust语言的主要原因在于Rust语言的安全性。Move语言是Libra的智能合约语言,由于Libra的目标是支付手段,因此设计Move时以安全性为第一考量。对于普通开发者来说,了解并学习Libra并不需要掌握Rust语言。不过如果需要深入理解Libra的细节,可以考虑学习Rust语言。关于如何学习Rust语言,网上有很多资料,这里不在赘述。

接下来,简单介绍如何从源代码开始编译并使用Libra。这里所有的操作都是基于macOS或者Linux,需要提前安装git,如果是macOS,需要提前安装homebrew,如果是Linux需要安装yum或者apt-get。


编译


从github clone libra源代码。

git clone https://github.com/libra/libra.git

然后,执行如下命令,进行安装依赖。

cd libra./scripts/dev_setup.sh

通过setup脚本,主要做了:

  • 安装rustup,这是rust语言的安装程序

  • 安装对应版本的rust-toolchain(记录在rust-toolchain文件中)

  • 安装cmake

  • 安装protoc,从系统架构来看,libra实际上典型的微服务架构,多个微服务之间通过grpc通信,因此需要protoc

  • 安装go,编译protobuf的时候需要


执行如下命令进行编译。

source ~/.cargo/envcargo buildcargo test

如果上述步骤都成功,那么恭喜你,接下来就可以玩Libra了。通常如果本地存在PB版本太低的时候,可能会编译失败,处理方法就是升级PB。如果有其他问题,可以Google解决,如果还无法解决,可以在本文后留言。


使用测试网络


Libra测试网络已经上线,通过以下脚本可以使用libra测试网络。

./scripts/cli/start_cli_testnet.sh
一旦连到testnet,如下图所示:

如果不想使用libra测试网络,也可以自己启动本地网络。


使用本地网络


通过如下命令可以使用本地网络。

cd libracargo run -p libra-swarm -- -s -n 4

如果运行成功,也会出现上面图片中类似的输出。

通过libra_swarm只是启动了本地单节点网络,通常用于方便测试。对于区块链来说,正常的网络都是有多个节点,搭建多测试节点的步骤较为复杂。

首先生成faucet密钥

./target/debug/generate-keypair -o data/libra_local_network/mint.key


生成节点配置,我们在这里使用三节点网络,

./target/debug/libra-config -b config/data/configs/node.config.toml -m data/libra_local_network/mint.key -n3 -o data/nodes

分别启动节点:

./target/debug/libra-node -f data/nodes/0/node.config.toml ./target/debug/libra-node -f data/nodes/1/node.config.toml./target/debug/libra-node -f data/nodes/3/node.config.toml

通过如下命令启动cli并连到第一个节点:

./target/debug/client -a localhost -p 49479 -s "data/nodes/0/consensus_peers.config.toml" -m "data/libra_local_network/mint.key"

需要注意的是,端口号要和data/nodes/0/node.config.toml中admission_control部分admission_control_service_port 端口保持一致。正常启动后,也能看到类似上图的输出。


创建帐号


完成上述步骤后,我们就可以创建帐号了。

libra% account create

命令成功运行后,会有如下输出:
#0代表帐号索引,16进制的字符串是帐号地址。可以使用account list命令来查看已经创建的账户。

接下来使用account mint命令给账户挖钱。

account mint 0 10000

0是账户索引,10000是我们要挖10000个libra币。这个命令是为了测试方便而存在的。完成后可以查看账户余额:

query balance 0

其中0也是账户索引。


转账


再通过上述步骤创建一个新账户,然后通过第一个账户向第二个账户转账:

transfer 0 1 10

和之前一样,0和1都是账户索引,10是转账金额。这个命令的作用就是第一个账户向第二个账户转账10个libra币。可以通过query balance来查看是否转账成功,各位读者可以自行验证。


使用move语言


关于move语言的语法细节,可以参考libra官方文档,这里不在赘述。Move将其基本组织结构分为module和script,module相当于其他语言中的库,script中包含main函数可以引用多个module,是执行合约的入口。module如下所示,主要作用是将libra币move到另一个帐号:

module MyModule { import 0x0.LibraCoin;//引入官方的module
public id(c: LibraCoin.T): LibraCoin.T { return move(c); }}

script如下所示,主要作用是将libra币从交易发送方move出来,然后move回交易发送方:

import 0x0.LibraAccount;import 0x0.LibraCoin;import {{sender}}.MyModule;
main(amount: u64) { let coin: LibraCoin.T; coin = LibraAccount.withdraw_from_sender(move(amount));
LibraAccount.deposit(get_txn_sender(), MyModule.id(move(coin))); return;}

可以通过如下命令,编译module:

dev compile 0 <path to my_module.mvir> moduleSuccessfully compiled a program at /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpigAZCx

然后发布module:

dev publish 0 /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpigAZCx
发布成功后,会输出Successfully published module.


通过如下命令编译script:

dev compile 0 <path_to_custom_script.mvir> scriptSuccessfully compiled a program at /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpDZhL21

通过如下命令执行脚本:

dev execute 0 /var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpDZhL21 10

其中0代表账户索引,/var/folders/tq/8gxrrmhx16376zxd5r4h9hhn_x1zq3/T/.tmpDZhL21是编译后的文件输出,10是脚本参数,在这个脚本里就是amount。如果成功执行脚本,也会输出Successfully finished execution。

关于Libra本身我们就介绍到这里,最后简单介绍我们团队现在的项目--stargate[1],现在是一个基于libra的二层项目,主要致力于开发libra之上的交易通道,后期会用我们自己的一层网络替代libra,欢迎各位有识之士拍砖。


文中链接:

[1]https://github.com/starcoinorg/stargate


相关阅读:



技术原创及架构实践文章,欢迎通过公众号菜单「联系我们」进行投稿。转载请注明来自高可用架构「ArchNotes」微信公众号及包含以下二维码。


高可用架构

改变互联网的构建方式

长按二维码 关注「高可用架构」公众号


Modified on

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存